## Εργαστηριακή εργασία 2 2016-2017 Περιγραφή

## Εκτελέσατε την ακόλουθη διαδικασία.

- 1. Εκκινήστε τον προσομοιωτή QtSpims.
- 2. Από το μενού "SIMULATOR" επιλέξτε "SETTINGS/Simple Machine/OK".
- 3. Αλλάξτε το περιεχόμενο του PC κάνοντας:
  - α. δεξί κλικ με το ποντίκι στον καταχωρητή PC,
  - β. στο πίνακα επιλογών που θα εμφανιστεί κάνετε αριστερό κλικ στην επιλογή "Change Register Contents",
  - γ. εγγράψτε στο κενό πεδίο του εικονιδίου που θα εμφανισθεί όταν επιλέξετε "Change Register Contents" τη δεκαεξαδική τιμή 20000000 (χωρίς το πρόθεμα 0x),
  - δ. Ολοκληρώστε την αλλαγή του περιεχομένου του PC πατώντας το πλήκτρο ΟΚ.
- Θέσατε σημείο διακοπής στη διεύθυνση 0x80000180 από την οποία αρχίζει το πρόγραμμα του λειτουργικού συστήματος που διαχειρίζεται μερικές εξαιρέσεις.
- 5. Από το μενού «SIMULATOR" ξεκινήστε το τρέξιμο προγράμματος επιλέγοντας «RUN/COTINUE". Σε απάντηση της επιλογής αυτής θα λάβετε μήνυμα " Exception occurred at PC=0x20000000", επειδή ξεκινήσατε τον υπολογιστή με μη επιτρεπτή διεύθυνση για πρόγραμμα χρήστη. Πατήστε "abort" για να αφαιρέσετε από την οθόνη σας το μήνυμα.
- Παρατηρήστε ότι ο υπολογιστής σταμάτησε στη διεύθυνση 0x800000180 από όπου αρχίζει η διαδικασία εξυπηρέτησης των εξαιρέσεων.
- 7. Να εκτελέσετε εντολή προς εντολή τη διαδικασία αυτή για να καταλάβετε τι λειτουργία επιτελείται από κάθε μια εντολή.
- 8. Αν επαναλάβετε τη διαδικασία από την αρχή (βήμα 1) χωρίς να θέσετε σημείο διακοπής τότε θα παρατηρήσετε ότι στην κονσόλα (console) τυπώνεται το μήνυμα:

Exception 6 [bad instruction address] occurred and ignored ενώ στο αναδυόμενο εικονίδιο αναγράφεται το μήνυμα Exception occurred at PC=0x200000004.

Κάθε εξεταζόμενος φοιτητής πρέπει να είναι σε θέση να αναλύει το περιεχόμενο των καταχωρητών Cause, Status, EPC και BadVAddr και να εντοπίζει εντολές που

ενδέχεται να προκαλέσουν αλλαγή των καταχωρητών αυτών, καθώς επίσης και τα τμήματα του προγράμματος των εξαιρέσεων που εκτυπώνουν τις λέξεις του μηνύματος που εμφανίζεται στην κονσόλα στο βήμα 8.

Παραδείγματα ερωτήσεων που θα μπορούσαν να τεθούν είναι:

- Να βρεθεί η διεύθυνση της εντολής στην οποία πρέπει να τεθεί σημείο διακοπής έτσι ώστε να τυπωθεί στην οθόνη μόνο το τμήμα "Exception 6" από το πλήρες μήνυμα του βήματος 8.
- 2. Να βρεθούν οι εντολές που βρίσκουν τον κώδικα της εξαίρεσης, π.χ. 6.
- 3. Ποια είναι η διεύθυνση της εντολής του προγράμματος των εξαιρέσεων που καθιστά τον MIPS ικανό να αναγνωρίζει εξαιρέσεις και διακοπές.
- 4. Τι τιμή θα έχουν οι καταχωρητές Cause και Status όταν συμβεί εξαίρεση αριθμητικής υπερχείλισης;
- 5. ....... 4) (ause\_ Exc. Cope. 1100 Interryt @ level 1 Status oxc. bit 1 -> exc. occurs interriget anable & wer mode L mash: nel 1 (on anuguines) 1 po un kasearei o enefeppaons no en étaipen T) "Exception : 6 [8000 orgg] Exception 6": @ [8 000 016c] No= 44 2) mfc 0 sko, \$13 sre \$ a0, \$60, \$2 andi \$00, \$00, 0x18 li no, 1 systall. 3) be \$00, 0, ret - exception interrupt -

| · (o-Processor O registers in SPIM                                                        |
|-------------------------------------------------------------------------------------------|
| Badvade 8 memory address at which an offending memory reference occurs                    |
| Count of time                                                                             |
| Compare     value compared against times that courses intermed den the                    |
| Status 12 interrupt mark and enable bits                                                  |
| Cause 13 exception type and pending interrupt bits                                        |
| EPC 19 address of instruction that caused exception                                       |
| Config 16 configuration of machine                                                        |
| 4 m/cO, mtcO instruction                                                                  |
| if bit BD of cause is enabled then look at EDC+42 for the afforting instance              |
| La Status Register                                                                        |
| 15 8 4 10                                                                                 |
| user exception interrupt mode come                                                        |
| Interrupt mask                                                                            |
| interrupt levels:                                                                         |
| bit = 1 enables interrupt at that land to interrupt processor                             |
| bit = 0 disables interrupt at that book                                                   |
| When an interrupt arrives it sets its interrupt ponding bit to 1 in the case              |
| register even if the mach bis is disubsed. When an interrupt is pouring it will interrupt |
| the processor when its mash 64 becomes 1                                                  |
| ti) Exception level bit is normally 0, but is set to 1 if on exception occurs.            |
| When it is I interrupts are disabled and the EPC is not updated if another                |
| exception accord                                                                          |
| - iz Interrupt endile = & interrupts allower                                              |
|                                                                                           |
|                                                                                           |
|                                                                                           |
|                                                                                           |
|                                                                                           |
|                                                                                           |
|                                                                                           |

